package 数据结构和算法.算法.排序算法.选择排序;

import java.util.Arrays;

/**
 * 每一趟排序，将最大的那个排到末尾
 * <p>
 * 非稳定性排序
 */
public class SelectionSort {
    public static void main(String[] args) {
        int[] array = {1, 3, 7, 2, 3, 5, 1};
        sort(array);
        System.out.printf(Arrays.toString(array));
    }

    public static void sort(int[] array) {
        for (int i = 0; i < array.length - 1; ++i) {
            int max = 0;
            for (int j = 0; j < array.length - i; ++j) {
                if (array[j] > array[max]) {
                    max = j;
                }
            }

            int temp = array[max];
            array[max] = array[array.length - i - 1];
            array[array.length - i - 1] = temp;
        }
    }
}
